<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>

<body>
    <button id="btn">btn</button>
    <script>
        var btn = document.querySelector("#btn");
        btn.addEventListener("click", debounce(function () {
            console.log(this);
        }))
        function debounce(fn, delay = 500) {
            let timer = null;
            return function () {
                if (timer) {
                    clearTimeout(timer)
                }
                timer = setTimeout(() => {
                    fn.call(this);
                }, delay)
            }
        }
    </script>
</body>

</html>